import Vue from 'vue'

import 'normalize.css/normalize.css' // A modern alternative to CSS resets

import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
// import locale from 'element-ui/lib/locale/lang/en' // lang i18n

import '@/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'

// import PageTools from '@/components/PageTools'
// Vue.component('PageTools', PageTools)
import Components from './components'
Vue.use(Components)
import Print from 'vue-print-nb'
Vue.use(Print)
import '@/icons' // icon
import '@/permission' // permission control
// import { color, imgerror } from './directives'
import * as directives from './directives'

// for (const key in directives) {
//   Vue.directive(key, directives[key])
// }
Object.keys(directives).forEach((item) => {
  Vue.directive(item, directives[item])
})
// set ElementUI lang to EN
Vue.use(ElementUI)
// 如果想要中文版 element-ui，按如下方式声明
// Vue.use(ElementUI)

Vue.config.productionTip = false
// 自定义指令
// Vue.directive('imgerror', imgerror)
// Vue.directive('color', color)

// 封装过滤器
import * as filters from '@/filters'
Object.keys(filters).forEach(key => {
  // 注册过滤器
  Vue.filter(key, filters[key])
})
new Vue({
  el: '#app',
  router,
  store,
  render: (h) => h(App)
})
